package cc.rengu.igas.share.core.service.channel.acct;

import cc.rengu.igas.acct.facade.base.Header;
import cc.rengu.igas.acct.facade.request.VirtAcctBalanceQueryRequest;
import cc.rengu.igas.acct.facade.response.VirtAcctBalanceQueryResponse;
import cc.rengu.igas.acct.facade.result.Result;
import cc.rengu.igas.share.common.constant.ShareParamConstant;
import cc.rengu.igas.share.common.constant.ShareServiceConstant;
import cc.rengu.igas.share.common.constant.TransCacheConstant;
import cc.rengu.igas.share.core.model.MchntInfo;
import cc.rengu.igas.share.core.realize.MchntService;
import cc.rengu.igas.share.core.realize.impl.MchntServiceImpl;
import cc.rengu.oltp.service.base.ChannelBaseService;
import cc.rengu.oltp.service.common.constant.AppParamConstant;
import cc.rengu.oltp.service.common.constant.TreeNodeConstant;
import cc.rengu.oltp.service.common.entity.ChannelCallCfg;
import cc.rengu.oltp.service.common.entity.PayOrderInfo;
import cc.rengu.oltp.service.common.enums.ChannelCallModeEnum;
import cc.rengu.oltp.service.common.enums.OltpRpcdEnum;
import cc.rengu.oltp.service.common.enums.TransStatusEnum;
import cc.rengu.oltp.service.model.BizException;
import cc.rengu.oltp.service.model.BizResponse;
import cc.rengu.oltp.service.model.OrderInfo;
import cc.rengu.oltp.service.model.TxnInfo;
import cc.rengu.oltp.service.realize.DubboService;
import cc.rengu.oltp.service.realize.impl.DubboServiceImpl;
import cc.rengu.oltp.utility.util.StringUtil;
import cc.rengu.oltp.utility.util.XmlTreeUtil;
import com.alibaba.fastjson.JSON;

/**
 * 虚拟账户余额查询
 * Created by lzl on 2021/4/23 11:08
 */
public class VirtAcctBalanceQueryService extends ChannelBaseService {
    @Override
    public Object callPreProc(TxnInfo txnInfo, ChannelCallCfg channelCallCfg, OrderInfo orderInfo) throws Exception {
        XmlTreeUtil xmlTreeUtil = new XmlTreeUtil();
        Header acctHeader = new Header();
        acctHeader.setInstId(xmlTreeUtil.getXmlTreeStringValue(TreeNodeConstant.INST_ID));
        acctHeader.setChanlId(channelCallCfg.getMsgSrcId());
        acctHeader.setSrcSysId(AppParamConstant.SYS_ID);
        acctHeader.setBizType(AppParamConstant.DEFAULT_BIZ_TYPE);
        acctHeader.setVersion(ShareParamConstant.DUBBO_VSERSION);
        acctHeader.setTxnNum(channelCallCfg.getCallChannelTxn());
        acctHeader.setTraceNo(xmlTreeUtil.getXmlTreeStringValue(TreeNodeConstant.SYS_SEQ_NUM) + channelCallCfg.getCallIndex());
        acctHeader.setTransTime(xmlTreeUtil.getXmlTreeStringValue(TreeNodeConstant.TRANS_TIME));
        acctHeader.setTransDate(xmlTreeUtil.getXmlTreeStringValue(TreeNodeConstant.TRANS_DATE));
        VirtAcctBalanceQueryRequest virtAcctBalanceQueryRequest = new VirtAcctBalanceQueryRequest();
        virtAcctBalanceQueryRequest.setHeader(acctHeader);

        MchntService mchntService = new MchntServiceImpl();
        MchntInfo mchntInfo = mchntService.getMchntInfo(acctHeader.getInstId(), xmlTreeUtil.getXmlTreeStringValue(TreeNodeConstant.MCHNT_NO));
        //userType : 00-商户  01-会员 02-营销
        virtAcctBalanceQueryRequest.setUserType("00");
        virtAcctBalanceQueryRequest.setUserId(mchntInfo.getMchntNo());
        //虚拟账户
        virtAcctBalanceQueryRequest.setAcctType("00");
        rglog.debug("虚拟账户余额查询请求:<{}>", JSON.toJSONString(virtAcctBalanceQueryRequest));

        return virtAcctBalanceQueryRequest;
    }

    @Override
    public PayOrderInfo generatePayOrderInfo(ChannelCallCfg channelCallCfg, OrderInfo orderInfo, Object request) throws Exception {
        return null;
    }

    @Override
    public Object callProc(ChannelCallCfg channelCallCfg, Object request) throws Exception {
        VirtAcctBalanceQueryRequest virtAcctBalanceQueryRequest = (VirtAcctBalanceQueryRequest) request;
        /* Step1：调用接口，获取结果 */
        Result<VirtAcctBalanceQueryResponse> callResult;
        DubboService dubboService = new DubboServiceImpl();
        if (AppParamConstant.YES.equals(channelCallCfg.getSyncCallFlag())) {
            /* Step1.1：异步调用 */
            int iReturnCode;
            int callTimes = 0 == channelCallCfg.getSyncQueryRepeatNum() ? 1 : channelCallCfg.getSyncQueryRepeatNum();
            int gatTime = channelCallCfg.getSyncQueryRepeatTime();
            int gatType = StringUtil.isEmptyOrNull(channelCallCfg.getSyncQueryGapType()) ? 0 : Integer.parseInt(channelCallCfg.getSyncQueryGapType());
            if (ChannelCallModeEnum.LOCAL.getMode().equals(channelCallCfg.getChannelCallMode())) {
                /* Step1.1.1：异步应用内调用 */
                Class clasz = Class.forName(ShareServiceConstant.VIRT_ACCT_SERVICE_INNER_PATH);
                iReturnCode = dubboService.asynCallDubboInnerMethod(clasz, ShareServiceConstant.VIRT_ACCT_BALANCE_QUERY_METHOD, virtAcctBalanceQueryRequest, channelCallCfg.getSyncResultServiceName(), callTimes, gatType, gatTime);
            } else if (ChannelCallModeEnum.REMOTE.getMode().equals(channelCallCfg.getChannelCallMode())) {
                /* Step1.1.2：异步远程调用 */
                iReturnCode = dubboService.asynCallDubboService(ShareServiceConstant.VIRT_ACCT_SERVICE, ShareServiceConstant.VIRT_ACCT_BALANCE_QUERY_METHOD, virtAcctBalanceQueryRequest, channelCallCfg.getSyncResultServiceName(), callTimes, gatType, gatTime);
            } else {
                rglog.error("不支持的通道服务调用方式:{}，交易拒绝!", channelCallCfg.getChannelCallMode());
                throw new BizException(OltpRpcdEnum.CALL_BIZ_SERVICE_ERROR);
            }
            if (0 == iReturnCode) {
                return new BizResponse<>(OltpRpcdEnum.TRANS_SUCCESS.getRespCode(), OltpRpcdEnum.TRANS_SUCCESS.getRespDesc());
            } else {
                return new BizResponse<>(OltpRpcdEnum.CALL_BIZ_SERVICE_ERROR.getRespCode(), OltpRpcdEnum.CALL_BIZ_SERVICE_ERROR.getRespDesc());
            }
        } else {
            /* Step1.2：同步调用 */
            if (ChannelCallModeEnum.LOCAL.getMode().equals(channelCallCfg.getChannelCallMode())) {
                /* Step1.2.1：同步应用内调用 */
                Class clasz = Class.forName(ShareServiceConstant.VIRT_ACCT_SERVICE_INNER_PATH);
                callResult = (Result<VirtAcctBalanceQueryResponse>) dubboService.callDubboInnerMethod(clasz, ShareServiceConstant.VIRT_ACCT_BALANCE_QUERY_METHOD, virtAcctBalanceQueryRequest);
            } else if (ChannelCallModeEnum.REMOTE.getMode().equals(channelCallCfg.getChannelCallMode())) {
                /* Step1.2.2：同步远程调用 */
                callResult = (Result<VirtAcctBalanceQueryResponse>) dubboService.callDubboService(ShareServiceConstant.VIRT_ACCT_SERVICE, ShareServiceConstant.VIRT_ACCT_BALANCE_QUERY_METHOD, virtAcctBalanceQueryRequest);
            } else {
                rglog.error("不支持的通道服务调用方式:{}，交易拒绝!", channelCallCfg.getChannelCallMode());
                throw new BizException(OltpRpcdEnum.CALL_BIZ_SERVICE_ERROR);
            }
        }
        return callResult;
    }

    @Override
    public Object querySyncCallResult(PayOrderInfo payOrderInfo, Object request) {
        return null;
    }

    @Override
    public OrderInfo callResultOrderProc(OrderInfo orderInfo, String payOrderIndex, TransStatusEnum transStatusEnum, Object response) {
        return null;
    }
}
